// 入口文件
import Vue from 'vue'
// 1.1 导入路由的包
import VueRouter from 'vue-router'
// 1.2 安装路由
Vue.use(VueRouter);


//注册vuex
import Vuex from 'vuex'
Vue.use(Vuex);

//每把次刚进入网站，肯定会调用main.js在刚调用的时候，先从本地存储中，把购物车的数据渡出来，放到store中
var car = JSON.parse(localStorage.getItem('car') || '[]')

var store = new Vuex.Store({
  state:{    //this.$store.state.***
    car: car  //将购物车中的商品的数据，用一数组存储起来，在car数组中，存储一些商品的对象，咱们可以暂时将这个商品对象，设计成这个样子{id：商品的id，count：要购买的数量，price：商品的单价，selected:false}
  },
  mutations:{     //this.$store.commit('方法的名称','按需传递唯一的参数')
  addToCar(state,goodsinfo){
    //点击加入购物车，把商品信息，保存到store中的car上
    //分析：
    //1.如果购物车中，之前就已经有这个对应的商品了，那么只需要更新数量
    //2.如果没有，则直接把商品数据，push到car中即可

    //假设在购物车中，没有找到对应的商品
    var flag = false


    state.car.some(item=>{
      if(item.id==goodsinfo.id) {
        item.count += parseInt(goodsinfo.count)
        flag = true
        return true
      }
    })
    
     //如果最终，循环完毕，得动的flag还是false，则把商品数据直接push到购物车中
    if(!flag){
      state.car.push(goodsinfo)
    }
    
    //当更新car之后，把car数组，存储到本地的localstorage中
    localStorage.setItem('car',JSON.stringify(state.car))
   },  
   updateGoodsInfo(state,goodsinfo){
     //修改购物车中商品的数量值
     //分析：
     state.car.some(item=>{
       if(item.id==goodsinfo.id){
         item.count = parseInt(goodsinfo.count)
         return true
       }
     })
      //当修改完商品的数量，把最新的购物车数据，保存到本地存储中
     localStorage.setItem('car',JSON.stringify(state.car))
   },
   romoveFormCar(state,id){
    //根据id，从store中的购物车中删除对用的那条商品数据
    state.car.some((item,i)=>{
      if(item.id==id){
        state.car.splice(i,1)
        return true;
      }
    })
    //将删除完毕后的，最新的购物车数据，同步到本地存储中
    localStorage.setItem('car',JSON.stringify(state.car))
   },
   updateGoodsSelected(state,info){
     state.car.some(item=>{
      if(item.id==info.id){
        item.selected = info.selected 
      }
     })
     //把最新的所有的购物车商品的状态保存到store中去
     localStorage.setItem('car',JSON.stringify(state.car))
      
   }  
  },
  getters:{    //this.$store.getters.***
    //相当于计算属性，也相当于filters
    getAllCount(state){
      var c = 0;
      state.car.forEach(item=>{
        c += item.count
      })
       return c
    },
    getGoodsCount(state){
      var o = {}
      state.car.forEach(item=>{
        o[item.id] = item.count
      })
      return o
    },
    getGoodsSelected(state){
     var o = {}
     state.car.forEach(item=>{
       o[item.id] = item.selected
     })
     return o
    },
    getGoodsCountAndAmount(state){
      var o = {
        count:0,   //勾选的数量
        amount:0    //勾选的总价
      }
      state.car.forEach(item=>{
        if(item.selected){
          o.count += item.count
          o.amount += item.price*item.count
        }
      })
      return o
    }
  }
})



//导入格式化时间的插件
import moment from 'moment'
//定义全局的过滤器
Vue.filter('dateFormat',function(dataStr,pattern ="YYYY-MM-DD HH:mm:ss"){
 return moment(dataStr).format(pattern)
})


// 2.1 导入 vue-resource
import VueResource from 'vue-resource'
// 2.2 安装 vue-resource
Vue.use(VueResource)
//设置请求的根路径
Vue.http.options.root = 'http://liulongbin.top:3005';
//全局设置post时候表单数据格式组织形式  application/x-www-form-urlencoded
Vue.http.options.emulateJSON = true;


// 导入 MUI 的样式
import './lib/mui/css/mui.min.css'
// 导入扩展图标样式
import './lib/mui/css/icons-extra.css'


// 按需导入 Mint-UI 中的组件   
// import { Header, Swipe, SwipeItem,Button,Lazyload } from 'mint-ui'
// Vue.component(Header.name, Header)
// Vue.component(Swipe.name, Swipe)
// Vue.component(SwipeItem.name, SwipeItem)
// Vue.component(Button.name,Button)
// Vue.use(Lazyload);
import MintUI from 'mint-ui'
Vue.use(MintUI)
import 'mint-ui/lib/style.css'


//安装图片预览插件
import VuePreview from 'vue-preview'
Vue.use(VuePreview)


// 1.3 导入自己的 router.js 路由模块
import router from './router.js'


// 导入 App 根组件
import app from './App.vue'

var vm = new Vue({
  el: '#app',
  render: c => c(app),
  router, // 1.4 挂载路由对象到 VM 实例上
  store   //挂载store状态管理对象
})